<?php

// Global variable for table object
$clientesTrabajo = NULL;

//
// Table class for clientesTrabajo
//
class cclientesTrabajo {
	var $TableVar = 'clientesTrabajo';
	var $TableName = 'clientesTrabajo';
	var $TableType = 'TABLE';
	var $id;
	var $IdCliente;
	var $TrabajoFechaIngreso;
	var $TrabajoFechaFin;
	var $TrabajoCuit;
	var $TrabajoRazonSocial;
	var $TrabajoCalle;
	var $TrabajoNumero;
	var $TrabajoPiso;
	var $TrabajoTelefono;
	var $TrabajoEntreCalles;
	var $TrabajoCargo;
	var $TrabajoIngreso;
	var $TrabajoPuesto;
	var $TrabajoProvincia;
	var $TrabajoLocalidad;
	var $TrabajoCP;
	var $Habilitada;
	var $fields = array();
	var $UseTokenInUrl = EW_USE_TOKEN_IN_URL;
	var $Export; // Export
	var $ExportOriginalValue = EW_EXPORT_ORIGINAL_VALUE;
	var $ExportAll = TRUE;
	var $SendEmail; // Send email
	var $TableCustomInnerHtml; // Custom inner HTML
	var $BasicSearchKeyword; // Basic search keyword
	var $BasicSearchType; // Basic search type
	var $CurrentFilter; // Current filter
	var $CurrentOrder; // Current order
	var $CurrentOrderType; // Current order type
	var $RowType; // Row type
	var $CssClass; // CSS class
	var $CssStyle; // CSS style
	var $RowAttrs = array(); // Row custom attributes
	var $TableFilter = "";
	var $CurrentAction; // Current action
	var $UpdateConflict; // Update conflict
	var $EventName; // Event name
	var $EventCancelled; // Event cancelled
	var $CancelMessage; // Cancel message

	//
	// Table class constructor
	//
	function cclientesTrabajo() {
		global $Language;

		// id
		$this->id = new cField('clientesTrabajo', 'clientesTrabajo', 'x_id', 'id', '[id]', 3, -1, FALSE, '[id]', FALSE);
		$this->id->FldDefaultErrMsg = $Language->Phrase("IncorrectInteger");
		$this->fields['id'] =& $this->id;

		// IdCliente
		$this->IdCliente = new cField('clientesTrabajo', 'clientesTrabajo', 'x_IdCliente', 'IdCliente', '[IdCliente]', 3, -1, FALSE, '[IdCliente]', FALSE);
		$this->IdCliente->FldDefaultErrMsg = $Language->Phrase("IncorrectInteger");
		$this->fields['IdCliente'] =& $this->IdCliente;

		// TrabajoFechaIngreso
		$this->TrabajoFechaIngreso = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoFechaIngreso', 'TrabajoFechaIngreso', '[TrabajoFechaIngreso]', 202, -1, FALSE, '[TrabajoFechaIngreso]', FALSE);
		$this->TrabajoFechaIngreso->FldDefaultErrMsg = str_replace("%s", "/", $Language->Phrase("IncorrectDateDMY"));
		$this->fields['TrabajoFechaIngreso'] =& $this->TrabajoFechaIngreso;

		// TrabajoFechaFin
		$this->TrabajoFechaFin = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoFechaFin', 'TrabajoFechaFin', '[TrabajoFechaFin]', 202, -1, FALSE, '[TrabajoFechaFin]', FALSE);
		$this->TrabajoFechaFin->FldDefaultErrMsg = str_replace("%s", "/", $Language->Phrase("IncorrectDateDMY"));
		$this->fields['TrabajoFechaFin'] =& $this->TrabajoFechaFin;

		// TrabajoCuit
		$this->TrabajoCuit = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoCuit', 'TrabajoCuit', '[TrabajoCuit]', 130, -1, FALSE, '[TrabajoCuit]', FALSE);
		$this->fields['TrabajoCuit'] =& $this->TrabajoCuit;

		// TrabajoRazonSocial
		$this->TrabajoRazonSocial = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoRazonSocial', 'TrabajoRazonSocial', '[TrabajoRazonSocial]', 130, -1, FALSE, '[TrabajoRazonSocial]', FALSE);
		$this->fields['TrabajoRazonSocial'] =& $this->TrabajoRazonSocial;

		// TrabajoCalle
		$this->TrabajoCalle = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoCalle', 'TrabajoCalle', '[TrabajoCalle]', 130, -1, FALSE, '[TrabajoCalle]', FALSE);
		$this->fields['TrabajoCalle'] =& $this->TrabajoCalle;

		// TrabajoNumero
		$this->TrabajoNumero = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoNumero', 'TrabajoNumero', '[TrabajoNumero]', 130, -1, FALSE, '[TrabajoNumero]', FALSE);
		$this->fields['TrabajoNumero'] =& $this->TrabajoNumero;

		// TrabajoPiso
		$this->TrabajoPiso = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoPiso', 'TrabajoPiso', '[TrabajoPiso]', 130, -1, FALSE, '[TrabajoPiso]', FALSE);
		$this->fields['TrabajoPiso'] =& $this->TrabajoPiso;

		// TrabajoTelefono
		$this->TrabajoTelefono = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoTelefono', 'TrabajoTelefono', '[TrabajoTelefono]', 130, -1, FALSE, '[TrabajoTelefono]', FALSE);
		$this->fields['TrabajoTelefono'] =& $this->TrabajoTelefono;

		// TrabajoEntreCalles
		$this->TrabajoEntreCalles = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoEntreCalles', 'TrabajoEntreCalles', '[TrabajoEntreCalles]', 130, -1, FALSE, '[TrabajoEntreCalles]', FALSE);
		$this->fields['TrabajoEntreCalles'] =& $this->TrabajoEntreCalles;

		// TrabajoCargo
		$this->TrabajoCargo = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoCargo', 'TrabajoCargo', '[TrabajoCargo]', 3, -1, FALSE, '[TrabajoCargo]', FALSE);
		$this->TrabajoCargo->FldDefaultErrMsg = $Language->Phrase("IncorrectInteger");
		$this->fields['TrabajoCargo'] =& $this->TrabajoCargo;

		// TrabajoIngreso
		$this->TrabajoIngreso = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoIngreso', 'TrabajoIngreso', '[TrabajoIngreso]', 131, -1, FALSE, '[TrabajoIngreso]', FALSE);
		$this->TrabajoIngreso->FldDefaultErrMsg = $Language->Phrase("IncorrectFloat");
		$this->fields['TrabajoIngreso'] =& $this->TrabajoIngreso;

		// TrabajoPuesto
		$this->TrabajoPuesto = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoPuesto', 'TrabajoPuesto', '[TrabajoPuesto]', 130, -1, FALSE, '[TrabajoPuesto]', FALSE);
		$this->fields['TrabajoPuesto'] =& $this->TrabajoPuesto;

		// TrabajoProvincia
		$this->TrabajoProvincia = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoProvincia', 'TrabajoProvincia', '[TrabajoProvincia]', 3, -1, FALSE, '[TrabajoProvincia]', FALSE);
		$this->TrabajoProvincia->FldDefaultErrMsg = $Language->Phrase("IncorrectInteger");
		$this->fields['TrabajoProvincia'] =& $this->TrabajoProvincia;

		// TrabajoLocalidad
		$this->TrabajoLocalidad = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoLocalidad', 'TrabajoLocalidad', '[TrabajoLocalidad]', 3, -1, FALSE, '[TrabajoLocalidad]', FALSE);
		$this->TrabajoLocalidad->FldDefaultErrMsg = $Language->Phrase("IncorrectInteger");
		$this->fields['TrabajoLocalidad'] =& $this->TrabajoLocalidad;

		// TrabajoCP
		$this->TrabajoCP = new cField('clientesTrabajo', 'clientesTrabajo', 'x_TrabajoCP', 'TrabajoCP', '[TrabajoCP]', 130, -1, FALSE, '[TrabajoCP]', FALSE);
		$this->fields['TrabajoCP'] =& $this->TrabajoCP;

		// Habilitada
		$this->Habilitada = new cField('clientesTrabajo', 'clientesTrabajo', 'x_Habilitada', 'Habilitada', '[Habilitada]', 3, -1, FALSE, '[Habilitada]', FALSE);
		$this->Habilitada->FldDefaultErrMsg = $Language->Phrase("IncorrectInteger");
		$this->fields['Habilitada'] =& $this->Habilitada;
	}

	// Table caption
	function TableCaption() {
		global $Language;
		return $Language->TablePhrase($this->TableVar, "TblCaption");
	}

	// Page caption
	function PageCaption($Page) {
		global $Language;
		$Caption = $Language->TablePhrase($this->TableVar, "TblPageCaption" . $Page);
		if ($Caption == "") $Caption = "Page " . $Page;
		return $Caption;
	}

	// Export return page
	function ExportReturnUrl() {
		$url = @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_EXPORT_RETURN_URL];
		return ($url <> "") ? $url : ew_CurrentPage();
	}

	function setExportReturnUrl($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_EXPORT_RETURN_URL] = $v;
	}

	// Records per page
	function getRecordsPerPage() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_REC_PER_PAGE];
	}

	function setRecordsPerPage($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_REC_PER_PAGE] = $v;
	}

	// Start record number
	function getStartRecordNumber() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_START_REC];
	}

	function setStartRecordNumber($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_START_REC] = $v;
	}

	// Search highlight name
	function HighlightName() {
		return "clientesTrabajo_Highlight";
	}

	// Advanced search
	function getAdvancedSearch($fld) {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_ADVANCED_SEARCH . "_" . $fld];
	}

	function setAdvancedSearch($fld, $v) {
		if (@$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_ADVANCED_SEARCH . "_" . $fld] <> $v) {
			$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_ADVANCED_SEARCH . "_" . $fld] = $v;
		}
	}

	// Basic search keyword
	function getSessionBasicSearchKeyword() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_BASIC_SEARCH];
	}

	function setSessionBasicSearchKeyword($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_BASIC_SEARCH] = $v;
	}

	// Basic search type
	function getSessionBasicSearchType() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_BASIC_SEARCH_TYPE];
	}

	function setSessionBasicSearchType($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_BASIC_SEARCH_TYPE] = $v;
	}

	// Search WHERE clause
	function getSearchWhere() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_SEARCH_WHERE];
	}

	function setSearchWhere($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_SEARCH_WHERE] = $v;
	}

	// Single column sort
	function UpdateSort(&$ofld) {
		if ($this->CurrentOrder == $ofld->FldName) {
			$sSortField = $ofld->FldExpression;
			$sLastSort = $ofld->getSort();
			if ($this->CurrentOrderType == "ASC" || $this->CurrentOrderType == "DESC") {
				$sThisSort = $this->CurrentOrderType;
			} else {
				$sThisSort = ($sLastSort == "ASC") ? "DESC" : "ASC";
			}
			$ofld->setSort($sThisSort);
			$this->setSessionOrderBy($sSortField . " " . $sThisSort); // Save to Session
		} else {
			$ofld->setSort("");
		}
	}

	// Session WHERE clause
	function getSessionWhere() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_WHERE];
	}

	function setSessionWhere($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_WHERE] = $v;
	}

	// Session ORDER BY
	function getSessionOrderBy() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_ORDER_BY];
	}

	function setSessionOrderBy($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_ORDER_BY] = $v;
	}

	// Session key
	function getKey($fld) {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_KEY . "_" . $fld];
	}

	function setKey($fld, $v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_KEY . "_" . $fld] = $v;
	}

	// Current master table name
	function getCurrentMasterTable() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_MASTER_TABLE];
	}

	function setCurrentMasterTable($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_MASTER_TABLE] = $v;
	}

	// Session master WHERE clause
	function getMasterFilter() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_MASTER_FILTER];
	}

	function setMasterFilter($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_MASTER_FILTER] = $v;
	}

	// Session detail WHERE clause
	function getDetailFilter() {
		return @$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_DETAIL_FILTER];
	}

	function setDetailFilter($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_DETAIL_FILTER] = $v;
	}

	// Master filter
	function SqlMasterFilter_cargos() {
		return "[id]=@id@";
	}

	// Detail filter
	function SqlDetailFilter_cargos() {
		return "[TrabajoCargo]=@TrabajoCargo@";
	}

	// Master filter
	function SqlMasterFilter_clientes() {
		return "[id]=@id@";
	}

	// Detail filter
	function SqlDetailFilter_clientes() {
		return "[IdCliente]=@IdCliente@";
	}

	// Table level SQL
	function SqlFrom() { // From
		return "[dbo].[clientesTrabajo]";
	}

	function SqlSelect() { // Select
		return "SELECT * FROM " . $this->SqlFrom();
	}

	function SqlWhere() { // Where
		$sWhere = "";
		$this->TableFilter = "";
		if ($this->TableFilter <> "") {
			if ($sWhere <> "") $sWhere = "(" . $sWhere . ") AND (";
			$sWhere .= "(" . $this->TableFilter . ")";
		}
		return $sWhere;
	}

	function SqlGroupBy() { // Group By
		return "";
	}

	function SqlHaving() { // Having
		return "";
	}

	function SqlOrderBy() { // Order By
		return "";
	}

	// Check if Anonymous User is allowed
	function AllowAnonymousUser() {
		switch (EW_PAGE_ID) {
			case "add":
			case "register":
			case "addopt":
				return FALSE;
			case "edit":
			case "update":
				return FALSE;
			case "delete":
				return FALSE;
			case "view":
				return FALSE;
			case "search":
				return FALSE;
			default:
				return FALSE;
		}
	}

	// Apply User ID filters
	function ApplyUserIDFilters($sFilter) {
		return $sFilter;
	}

	// Get SQL
	function GetSQL($where, $orderby) {
		return ew_BuildSelectSql($this->SqlSelect(), $this->SqlWhere(),
			$this->SqlGroupBy(), $this->SqlHaving(), $this->SqlOrderBy(),
			$where, $orderby);
	}

	// Table SQL
	function SQL() {
		$sFilter = $this->CurrentFilter;
		$sFilter = $this->ApplyUserIDFilters($sFilter);
		$sSort = $this->getSessionOrderBy();
		return ew_BuildSelectSql($this->SqlSelect(), $this->SqlWhere(),
			$this->SqlGroupBy(), $this->SqlHaving(), $this->SqlOrderBy(),
			$sFilter, $sSort);
	}

	// Table SQL with List page filter
	function SelectSQL() {
		$sFilter = $this->getSessionWhere();
		if ($this->CurrentFilter <> "") {
			if ($sFilter <> "") $sFilter = "(" . $sFilter . ") AND ";
			$sFilter .= "(" . $this->CurrentFilter . ")";
		}
		$sFilter = $this->ApplyUserIDFilters($sFilter);
		$sSort = $this->getSessionOrderBy();
		return ew_BuildSelectSql($this->SqlSelect(), $this->SqlWhere(), $this->SqlGroupBy(),
			$this->SqlHaving(), $this->SqlOrderBy(), $sFilter, $sSort);
	}

	// Try to get record count
	function TryGetRecordCount($sSql) {
		global $conn;
		$cnt = -1;
		if ($this->TableType == 'TABLE' || $this->TableType == 'VIEW') {
			$sSql = "SELECT COUNT(*) FROM" . substr($sSql, 13);
		} else {
			$sSql = "SELECT COUNT(*) FROM (" . $sSql . ") EW_COUNT_TABLE";
		}
		if ($rs = $conn->Execute($sSql)) {
			if (!$rs->EOF && $rs->FieldCount() > 0) {
				$cnt = $rs->fields[0];
				$rs->Close();
			}
		}
		return intval($cnt);
	}

	// Get record count based on filter (for detail record count in master table pages)
	function LoadRecordCount($sFilter) {
		$origFilter = $this->CurrentFilter;
		$this->CurrentFilter = $sFilter;
		$this->Recordset_Selecting($this->CurrentFilter);
		$sSql = $this->SQL();
		$cnt = $this->TryGetRecordCount($sSql);
		if ($cnt == -1) {
			if ($rs = $this->LoadRs($this->CurrentFilter)) {
				$cnt = $rs->RecordCount();
				$rs->Close();
			}
		}
		$this->CurrentFilter = $origFilter;
		return intval($cnt);
	}

	// Get record count (for current List page)
	function SelectRecordCount() {
		global $conn;
		$origFilter = $this->CurrentFilter;
		$this->Recordset_Selecting($this->CurrentFilter);
		$sSql = $this->SelectSQL();
		$cnt = $this->TryGetRecordCount($sSql);
		if ($cnt == -1) {
			if ($rs = $conn->Execute($this->SelectSQL())) {
				$cnt = $rs->RecordCount();
				$rs->Close();
			}
		}
		$this->CurrentFilter = $origFilter;
		return intval($cnt);
	}

	// INSERT statement
	function InsertSQL(&$rs) {
		global $conn;
		$names = "";
		$values = "";
		foreach ($rs as $name => $value) {
			$names .= $this->fields[$name]->FldExpression . ",";
			if (in_array($this->fields[$name]->FldType, array(130, 202, 203)) && !is_null($value))
				$values .= 'N';
			$values .= ew_QuotedValue($value, $this->fields[$name]->FldDataType) . ",";
		}
		if (substr($names, -1) == ",") $names = substr($names, 0, strlen($names)-1);
		if (substr($values, -1) == ",") $values = substr($values, 0, strlen($values)-1);
		return "INSERT INTO [dbo].[clientesTrabajo] ($names) VALUES ($values)";
	}

	// UPDATE statement
	function UpdateSQL(&$rs) {
		global $conn;
		$SQL = "UPDATE [dbo].[clientesTrabajo] SET ";
		foreach ($rs as $name => $value) {
			$SQL .= $this->fields[$name]->FldExpression . "=";
			if (in_array($this->fields[$name]->FldType, array(130, 202, 203)) && !is_null($value))
				$SQL .= 'N';
			$SQL .= ew_QuotedValue($value, $this->fields[$name]->FldDataType) . ",";
		}
		if (substr($SQL, -1) == ",") $SQL = substr($SQL, 0, strlen($SQL)-1);
		if ($this->CurrentFilter <> "")	$SQL .= " WHERE " . $this->CurrentFilter;
		return $SQL;
	}

	// DELETE statement
	function DeleteSQL(&$rs) {
		$SQL = "DELETE FROM [dbo].[clientesTrabajo] WHERE ";
		$SQL .= ew_QuotedName('id') . '=' . ew_QuotedValue($rs['id'], $this->id->FldDataType) . ' AND ';
		if (substr($SQL, -5) == " AND ") $SQL = substr($SQL, 0, strlen($SQL)-5);
		if ($this->CurrentFilter <> "")	$SQL .= " AND " . $this->CurrentFilter;
		return $SQL;
	}

	// Key filter WHERE clause
	function SqlKeyFilter() {
		return "[id] = @id@";
	}

	// Key filter
	function KeyFilter() {
		$sKeyFilter = $this->SqlKeyFilter();
		if (!is_numeric($this->id->CurrentValue))
			$sKeyFilter = "0=1"; // Invalid key
		$sKeyFilter = str_replace("@id@", ew_AdjustSql($this->id->CurrentValue), $sKeyFilter); // Replace key value
		return $sKeyFilter;
	}

	// Return page URL
	function getReturnUrl() {
		$name = EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_RETURN_URL;

		// Get referer URL automatically
		if (ew_ServerVar("HTTP_REFERER") <> "" && ew_ReferPage() <> ew_CurrentPage() && ew_ReferPage() <> "login.php") // Referer not same page or login page
			$_SESSION[$name] = ew_ServerVar("HTTP_REFERER"); // Save to Session
		if (@$_SESSION[$name] <> "") {
			return $_SESSION[$name];
		} else {
			return "clientesTrabajolist.php";
		}
	}

	function setReturnUrl($v) {
		$_SESSION[EW_PROJECT_NAME . "_" . $this->TableVar . "_" . EW_TABLE_RETURN_URL] = $v;
	}

	// List URL
	function ListUrl() {
		return "clientesTrabajolist.php";
	}

	// View URL
	function ViewUrl() {
		return $this->KeyUrl("clientesTrabajoview.php", $this->UrlParm());
	}

	// Add URL
	function AddUrl() {
		$AddUrl = "clientesTrabajoadd.php";
		$sUrlParm = $this->UrlParm();
		if ($sUrlParm <> "")
			$AddUrl .= "?" . $sUrlParm;
		return $AddUrl;
	}

	// Edit URL
	function EditUrl() {
		return $this->KeyUrl("clientesTrabajoedit.php", $this->UrlParm());
	}

	// Inline edit URL
	function InlineEditUrl() {
		return $this->KeyUrl(ew_CurrentPage(), $this->UrlParm("a=edit"));
	}

	// Copy URL
	function CopyUrl() {
		return $this->KeyUrl("clientesTrabajoadd.php", $this->UrlParm());
	}

	// Inline copy URL
	function InlineCopyUrl() {
		return $this->KeyUrl(ew_CurrentPage(), $this->UrlParm("a=copy"));
	}

	// Delete URL
	function DeleteUrl() {
		return $this->KeyUrl("clientesTrabajodelete.php", $this->UrlParm());
	}

	// Add key value to URL
	function KeyUrl($url, $parm = "") {
		$sUrl = $url . "?";
		if ($parm <> "") $sUrl .= $parm . "&";
		if (!is_null($this->id->CurrentValue)) {
			$sUrl .= "id=" . urlencode($this->id->CurrentValue);
		} else {
			return "javascript:alert(ewLanguage.Phrase(\"InvalidRecord\"));";
		}
		return $sUrl;
	}

	// Sort URL
	function SortUrl(&$fld) {
		if ($this->CurrentAction <> "" || $this->Export <> "" ||
			in_array($fld->FldType, array(141, 201, 203, 128, 204, 205))) { // Unsortable data type
				return "";
		} elseif ($fld->Sortable) {
			$sUrlParm = $this->UrlParm("order=" . urlencode($fld->FldName) . "&ordertype=" . $fld->ReverseSort());
			return ew_CurrentPage() . "?" . $sUrlParm;
		} else {
			return "";
		}
	}

	// Add URL parameter
	function UrlParm($parm = "") {
		$UrlParm = ($this->UseTokenInUrl) ? "t=clientesTrabajo" : "";
		if ($parm <> "") {
			if ($UrlParm <> "")
				$UrlParm .= "&";
			$UrlParm .= $parm;
		}
		return $UrlParm;
	}

	// Load rows based on filter
	function &LoadRs($sFilter) {
		global $conn;

		// Set up filter (SQL WHERE clause) and get return SQL
		$this->CurrentFilter = $sFilter;
		$sSql = $this->SQL();
		return $conn->Execute($sSql);
	}

	// Load row values from recordset
	function LoadListRowValues(&$rs) {
		$this->id->setDbValue($rs->fields('id'));
		$this->IdCliente->setDbValue($rs->fields('IdCliente'));
		$this->TrabajoFechaIngreso->setDbValue($rs->fields('TrabajoFechaIngreso'));
		$this->TrabajoFechaFin->setDbValue($rs->fields('TrabajoFechaFin'));
		$this->TrabajoCuit->setDbValue($rs->fields('TrabajoCuit'));
		$this->TrabajoRazonSocial->setDbValue($rs->fields('TrabajoRazonSocial'));
		$this->TrabajoCalle->setDbValue($rs->fields('TrabajoCalle'));
		$this->TrabajoNumero->setDbValue($rs->fields('TrabajoNumero'));
		$this->TrabajoPiso->setDbValue($rs->fields('TrabajoPiso'));
		$this->TrabajoTelefono->setDbValue($rs->fields('TrabajoTelefono'));
		$this->TrabajoEntreCalles->setDbValue($rs->fields('TrabajoEntreCalles'));
		$this->TrabajoCargo->setDbValue($rs->fields('TrabajoCargo'));
		$this->TrabajoIngreso->setDbValue($rs->fields('TrabajoIngreso'));
		$this->TrabajoPuesto->setDbValue($rs->fields('TrabajoPuesto'));
		$this->TrabajoProvincia->setDbValue($rs->fields('TrabajoProvincia'));
		$this->TrabajoLocalidad->setDbValue($rs->fields('TrabajoLocalidad'));
		$this->TrabajoCP->setDbValue($rs->fields('TrabajoCP'));
		$this->Habilitada->setDbValue($rs->fields('Habilitada'));
	}

	// Render list row values
	function RenderListRow() {
		global $conn, $Security;

		// Call Row Rendering event
		$this->Row_Rendering();

   // Common render codes
		// id

		$this->id->CellCssStyle = ""; $this->id->CellCssClass = "";
		$this->id->CellAttrs = array(); $this->id->ViewAttrs = array(); $this->id->EditAttrs = array();

		// TrabajoCuit
		$this->TrabajoCuit->CellCssStyle = ""; $this->TrabajoCuit->CellCssClass = "";
		$this->TrabajoCuit->CellAttrs = array(); $this->TrabajoCuit->ViewAttrs = array(); $this->TrabajoCuit->EditAttrs = array();

		// TrabajoRazonSocial
		$this->TrabajoRazonSocial->CellCssStyle = ""; $this->TrabajoRazonSocial->CellCssClass = "";
		$this->TrabajoRazonSocial->CellAttrs = array(); $this->TrabajoRazonSocial->ViewAttrs = array(); $this->TrabajoRazonSocial->EditAttrs = array();

		// TrabajoCargo
		$this->TrabajoCargo->CellCssStyle = ""; $this->TrabajoCargo->CellCssClass = "";
		$this->TrabajoCargo->CellAttrs = array(); $this->TrabajoCargo->ViewAttrs = array(); $this->TrabajoCargo->EditAttrs = array();

		// TrabajoProvincia
		$this->TrabajoProvincia->CellCssStyle = ""; $this->TrabajoProvincia->CellCssClass = "";
		$this->TrabajoProvincia->CellAttrs = array(); $this->TrabajoProvincia->ViewAttrs = array(); $this->TrabajoProvincia->EditAttrs = array();

		// TrabajoLocalidad
		$this->TrabajoLocalidad->CellCssStyle = ""; $this->TrabajoLocalidad->CellCssClass = "";
		$this->TrabajoLocalidad->CellAttrs = array(); $this->TrabajoLocalidad->ViewAttrs = array(); $this->TrabajoLocalidad->EditAttrs = array();

		// Habilitada
		$this->Habilitada->CellCssStyle = ""; $this->Habilitada->CellCssClass = "";
		$this->Habilitada->CellAttrs = array(); $this->Habilitada->ViewAttrs = array(); $this->Habilitada->EditAttrs = array();

		// id
		$this->id->ViewValue = $this->id->CurrentValue;
		$this->id->CssStyle = "";
		$this->id->CssClass = "";
		$this->id->ViewCustomAttributes = "";

		// TrabajoCuit
		$this->TrabajoCuit->ViewValue = $this->TrabajoCuit->CurrentValue;
		$this->TrabajoCuit->CssStyle = "";
		$this->TrabajoCuit->CssClass = "";
		$this->TrabajoCuit->ViewCustomAttributes = "";

		// TrabajoRazonSocial
		$this->TrabajoRazonSocial->ViewValue = $this->TrabajoRazonSocial->CurrentValue;
		$this->TrabajoRazonSocial->CssStyle = "";
		$this->TrabajoRazonSocial->CssClass = "";
		$this->TrabajoRazonSocial->ViewCustomAttributes = "";

		// TrabajoCargo
		if (strval($this->TrabajoCargo->CurrentValue) <> "") {
			$sFilterWrk = "[id] = " . ew_AdjustSql($this->TrabajoCargo->CurrentValue) . "";
		$sSqlWrk = "SELECT [NombreCargo] FROM [cargos]";
		$sWhereWrk = "";
		if ($sFilterWrk <> "") {
			if ($sWhereWrk <> "") $sWhereWrk .= " AND ";
			$sWhereWrk .= "(" . $sFilterWrk . ")";
		}
		if ($sWhereWrk <> "") $sSqlWrk .= " WHERE " . $sWhereWrk;
		$sSqlWrk .= " ORDER BY [NombreCargo] Asc";
			$rswrk = $conn->Execute($sSqlWrk);
			if ($rswrk && !$rswrk->EOF) { // Lookup values found
				$this->TrabajoCargo->ViewValue = $rswrk->fields('NombreCargo');
				$rswrk->Close();
			} else {
				$this->TrabajoCargo->ViewValue = $this->TrabajoCargo->CurrentValue;
			}
		} else {
			$this->TrabajoCargo->ViewValue = NULL;
		}
		$this->TrabajoCargo->CssStyle = "";
		$this->TrabajoCargo->CssClass = "";
		$this->TrabajoCargo->ViewCustomAttributes = "";

		// TrabajoProvincia
		if (strval($this->TrabajoProvincia->CurrentValue) <> "") {
			$sFilterWrk = "[id] = " . ew_AdjustSql($this->TrabajoProvincia->CurrentValue) . "";
		$sSqlWrk = "SELECT [Nombre] FROM [provincia]";
		$sWhereWrk = "";
		if ($sFilterWrk <> "") {
			if ($sWhereWrk <> "") $sWhereWrk .= " AND ";
			$sWhereWrk .= "(" . $sFilterWrk . ")";
		}
		if ($sWhereWrk <> "") $sSqlWrk .= " WHERE " . $sWhereWrk;
		$sSqlWrk .= " ORDER BY [Nombre] Asc";
			$rswrk = $conn->Execute($sSqlWrk);
			if ($rswrk && !$rswrk->EOF) { // Lookup values found
				$this->TrabajoProvincia->ViewValue = $rswrk->fields('Nombre');
				$rswrk->Close();
			} else {
				$this->TrabajoProvincia->ViewValue = $this->TrabajoProvincia->CurrentValue;
			}
		} else {
			$this->TrabajoProvincia->ViewValue = NULL;
		}
		$this->TrabajoProvincia->CssStyle = "";
		$this->TrabajoProvincia->CssClass = "";
		$this->TrabajoProvincia->ViewCustomAttributes = "";

		// TrabajoLocalidad
		if (strval($this->TrabajoLocalidad->CurrentValue) <> "") {
			$sFilterWrk = "[id] = " . ew_AdjustSql($this->TrabajoLocalidad->CurrentValue) . "";
		$sSqlWrk = "SELECT [Nombre] FROM [localidades]";
		$sWhereWrk = "";
		if ($sFilterWrk <> "") {
			if ($sWhereWrk <> "") $sWhereWrk .= " AND ";
			$sWhereWrk .= "(" . $sFilterWrk . ")";
		}
		if ($sWhereWrk <> "") $sSqlWrk .= " WHERE " . $sWhereWrk;
		$sSqlWrk .= " ORDER BY [Nombre] Asc";
			$rswrk = $conn->Execute($sSqlWrk);
			if ($rswrk && !$rswrk->EOF) { // Lookup values found
				$this->TrabajoLocalidad->ViewValue = $rswrk->fields('Nombre');
				$rswrk->Close();
			} else {
				$this->TrabajoLocalidad->ViewValue = $this->TrabajoLocalidad->CurrentValue;
			}
		} else {
			$this->TrabajoLocalidad->ViewValue = NULL;
		}
		$this->TrabajoLocalidad->CssStyle = "";
		$this->TrabajoLocalidad->CssClass = "";
		$this->TrabajoLocalidad->ViewCustomAttributes = "";

		// Habilitada
		if (strval($this->Habilitada->CurrentValue) <> "") {
			$this->Habilitada->ViewValue = "";
			$arwrk = explode(",", strval($this->Habilitada->CurrentValue));
			for ($ari = 0; $ari < count($arwrk); $ari++) {
				switch (trim($arwrk[$ari])) {
					case "1":
						$this->Habilitada->ViewValue .= "Habilitado";
						break;
					default:
						$this->Habilitada->ViewValue .= trim($arwrk[$ari]);
				}
				if ($ari < count($arwrk)-1) $this->Habilitada->ViewValue .= ew_ViewOptionSeparator($ari);
			}
		} else {
			$this->Habilitada->ViewValue = NULL;
		}
		$this->Habilitada->CssStyle = "";
		$this->Habilitada->CssClass = "";
		$this->Habilitada->ViewCustomAttributes = "";

		// id
		$this->id->HrefValue = "";
		$this->id->TooltipValue = "";

		// TrabajoCuit
		$this->TrabajoCuit->HrefValue = "";
		$this->TrabajoCuit->TooltipValue = "";

		// TrabajoRazonSocial
		$this->TrabajoRazonSocial->HrefValue = "";
		$this->TrabajoRazonSocial->TooltipValue = "";

		// TrabajoCargo
		$this->TrabajoCargo->HrefValue = "";
		$this->TrabajoCargo->TooltipValue = "";

		// TrabajoProvincia
		$this->TrabajoProvincia->HrefValue = "";
		$this->TrabajoProvincia->TooltipValue = "";

		// TrabajoLocalidad
		$this->TrabajoLocalidad->HrefValue = "";
		$this->TrabajoLocalidad->TooltipValue = "";

		// Habilitada
		$this->Habilitada->HrefValue = "";
		$this->Habilitada->TooltipValue = "";

		// Call Row Rendered event
		$this->Row_Rendered();
	}

	// Aggregate list row values
	function AggregateListRowValues() {
	}

	// Aggregate list row (for rendering)
	function AggregateListRow() {
	}

	// Row styles
	function RowStyles() {
		$sAtt = "";
		$sStyle = trim($this->CssStyle);
		if (@$this->RowAttrs["style"] <> "")
			$sStyle .= " " . $this->RowAttrs["style"];
		$sClass = trim($this->CssClass);
		if (@$this->RowAttrs["class"] <> "")
			$sClass .= " " . $this->RowAttrs["class"];
		if (trim($sStyle) <> "")
			$sAtt .= " style=\"" . trim($sStyle) . "\"";
		if (trim($sClass) <> "")
			$sAtt .= " class=\"" . trim($sClass) . "\"";
		return $sAtt;
	}

	// Row attributes
	function RowAttributes() {
		$sAtt = $this->RowStyles();
		if ($this->Export == "") {
			foreach ($this->RowAttrs as $k => $v) {
				if ($k <> "class" && $k <> "style" && trim($v) <> "")
					$sAtt .= " " . $k . "=\"" . trim($v) . "\"";
			}
		}
		return $sAtt;
	}

	// Field object by name
	function fields($fldname) {
		return $this->fields[$fldname];
	}

	// Table level events
	// Recordset Selecting event
	function Recordset_Selecting(&$filter) {

		// Enter your code here	
	}

	// Recordset Selected event
	function Recordset_Selected(&$rs) {

		//echo "Recordset Selected";
	}

	// Recordset Search Validated event
	function Recordset_SearchValidated() {

		// Example:
		//$this->MyField1->AdvancedSearch->SearchValue = "your search criteria"; // Search value

	}

	// Recordset Searching event
	function Recordset_Searching(&$filter) {

		// Enter your code here	
	}

	// Row_Selecting event
	function Row_Selecting(&$filter) {

		// Enter your code here	
	}

	// Row Selected event
	function Row_Selected(&$rs) {

		//echo "Row Selected";
	}

	// Row Rendering event
	function Row_Rendering() {

		// Enter your code here	
	}

	// Row Rendered event
	function Row_Rendered() {

		// To view properties of field class, use:
		//var_dump($this-><FieldName>); 

	}

	// Row Inserting event
	function Row_Inserting(&$rs) {

		// Enter your code here
		// To cancel, set return value to FALSE

		return TRUE;
	}

	// Row Inserted event
	function Row_Inserted(&$rs) {

		//echo "Row Inserted"
	}

	// Row Updating event
	function Row_Updating(&$rsold, &$rsnew) {

		// Enter your code here
		// To cancel, set return value to FALSE

		return TRUE;
	}

	// Row Updated event
	function Row_Updated(&$rsold, &$rsnew) {

		//echo "Row Updated";
	}

	// Row Update Conflict event
	function Row_UpdateConflict(&$rsold, &$rsnew) {

		// Enter your code here
		// To ignore conflict, set return value to FALSE

		return TRUE;
	}

	// Row Deleting event
	function Row_Deleting(&$rs) {

		// Enter your code here
		// To cancel, set return value to False

		return TRUE;
	}

	// Row Deleted event
	function Row_Deleted(&$rs) {

		//echo "Row Deleted";
	}

	// Email Sending event
	function Email_Sending(&$Email, &$Args) {

		//var_dump($Email); var_dump($Args); exit();
		return TRUE;
	}
}
?>
